package simple.number;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * @Desc <a href="https://leetcode.cn/problems/binary-watch/">401. 二进制手表</a>
 * 二进制手表顶部有 4 个 LED 代表 小时（0-11），底部的 6 个 LED 代表 分钟（0-59）。每个 LED 代表一个 0 或 1，最低位在右侧。
 * 即：小时以4个二进制位表示，分钟以6个二进制位表示
 * 给你一个整数 turnedOn ，表示当前亮着的 LED 的数量，返回二进制手表可以表示的所有可能时间。你可以 按任意顺序 返回答案。
 * 小时不会以零开头：
 *   例如，"01:00" 是无效的时间，正确的写法应该是 "1:00" 。
 * 分钟必须由两位数组成，可能会以零开头：
 *   例如，"10:2" 是无效的时间，正确的写法应该是 "10:02" 。
 * 示例 1：
 *   输入：turnedOn = 1
 *   输出：["0:01","0:02","0:04","0:08","0:16","0:32","1:00","2:00","4:00","8:00"]
 * 示例 2：
 *   输入：turnedOn = 9
 *   输出：[]
 * 提示：
 *   0 <= turnedOn <= 10
 * @Date 2023/2/8 19:07
 * @Created by 刘学松
 */
public class 二进制手表 {
    public List<String> readBinaryWatch(int turnedOn) {
        List<String> ans = new ArrayList<>();
        for (int h = 0; h < 12; ++h) {
            for (int m = 0; m < 60; ++m) {
                if (Integer.bitCount(h) + Integer.bitCount(m) == turnedOn) {
                    ans.add(h + ":" + (m < 10 ? "0" : "") + m);
                }
            }
        }
        return ans;
    }
}
